基于SQL Server中char,nchar,varchar,nvarchar的使用区别
)
FROM temptable WHERE id =2
SELECT DATALENGTH(charField) AS charFieldLen,charField,
INSERT INTO TempTable VALUES(1,'WFTH','WFTH','WFTH')
2.Unicode或非Unicode
SELECT DATALENGTH(charField) AS charFieldLen,SELECT DATALENGTH(charField) AS charFieldLen,
FROM temptable WHERE id =4
所谓定长就是长度固定,当要保存的数据长度不够时将自动在其后面填充英文空格,使长度达到相应的长度;有var前缀的,表示是实际存储空间是动态变化的,比如varchar,nvarchar变长字符数据则不会以空格填充。
nvarcharField NVARCHAR(10)FROM temptable WHERE id =5
DATALENGTH(varcharField) AS varcharFieldLen,
DATALENGTH(varcharField) AS varcharFieldLen,
CREATE TABLE TempTable(
DATALENGTH(nvarcharField) AS nvarcharFieldLen
INSERT INTO TempTable VALUES(2,'无风听海','无风听海','无风听海')
对于程序中的一般字符串类型的字段,SQL Server中有char、varchar、nchar、nvarchar四种类型来对应,那么这四种类型有什么区别呢,这里做一下对比。
nchar,nvarchar 最多可存储4000个字符,无论英文还是汉字
charField CHAR(10),
SELECT DATALENGTH(charField) AS charFieldLen,
1.定长或变长
SELECT DATALENGTH(charField) AS charFieldLen,复制代码 代码如下:
DATALENGTH(varcharField) AS varcharFieldLen,varcharField,FROM temptable WHERE id =1
INSERT INTO TempTable VALUES(5,'1234567890','1234567890','12345')
DATALENGTH(varcharField) AS varcharFieldLen,
varcharField VARCHAR(10),
DATALENGTH(nvarcharField) AS nvarcharFieldLen
DATALENGTH(nvarcharField) AS nvarcharFieldLen
FROM temptable WHERE id =3
id INT PRIMARY KEY,
INSERT INTO TempTable(id) VALUES(4)
DATALENGTH(nvarcharField) AS nvarcharFieldLen
char,varchar 最多8000个英文,4000个汉字
--创建表DATALENGTH(nvarcharField) AS nvarcharFieldLen,nvarcharField
3.几种数据类型的存储的最大容量
DATALENGTH(varcharField) AS varcharFieldLen,数据库中,英文字符只需要一个字节存储就足够了,但汉字和其他众多非英文字符,则需要两个字节存储。如果英文与汉字同时存在,由于占用空间数不同,容易造成混乱,导致读取出来的字符串是乱码。Unicode字符集就是为了解决字符集这种不兼容的问题而产生的,它所有的字符都用两个字节表示,即英文字符也是用两个字节表示。而前缀n就表示Unicode字符,比如nchar,nvarchar,这两种类型使用了Unicode字符集。
相关热词:
本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!
本文地址: https://v30.fanwenzhu.com/sql/mssql/3155.shtml
相关文章
热门TAG
win10 ecshop 主机 阿里云 解决 配置 C# C++ 解析 SQL语句 命令 Go语言 方法 CSS3 HTML5 CSS win7 MSSQL 服务器配置 IIS7.5 IIS7 IIS6 IIS CentOS 7 Linux oracle数据库 oracle phpcms discuz discuz教程最新文章
-
SQL基本教程之行转列Pivo
时间:2021-01-20
-
region from hr.Employees union
时间:2021-01-20
-
有时候需要调整用户权限
时间:2021-01-19
-
(但使用 ORDER BY 子句并不
时间:2021-01-19
-
RAND()*10000)insert into Detail
时间:2021-01-19
-
OR 运算符:在两侧的查询
时间:2021-01-19
-
放假之前老大跟我提起了
时间:2021-01-19
-
数据库的运维计策剧本篇
时间:2021-01-19
热门文章
-
4.与聚合函数和 GROUP BY 子句有关的常见错
时间:2021-01-19
-
SQL Server安全(11/11):审核(Auditing)
时间:2021-01-09
-
sqlserver中查询横表变竖表的sql语句简析
时间:2020-12-08
-
SQL Server简单模式下误删除堆表记录恢复方
时间:2020-12-12
-
关于SQL Server查询语句的使用
时间:2020-12-13
-
MSSQL教程_mssql数据库教程_MSSQL基础教程_第
时间:2020-12-13
-
jdbc连接sql server数据库问题分析
时间:2020-12-10
-
详解SQL游标的用法
时间:2020-12-27
-
sql server 关于设置null的一些建议
时间:2020-12-28
-
mssql关于一个表格结构的另外一种显示(表
时间:2020-12-11
